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ABSTRACT 


A special tagged arithmetic system has been developed for use with FORTRAN pro- 
grams written to process experimental data. The tagged arithmetic system carries a 
condition code with every numerical value and uses a special output to call attention to 
answers computed by using questionable input data. The questionable input data may 
result from instrumentation or data recording system malfunctions, which can cause 
ill-conditioned calculations that result in process-time faults or error conditions. 



TAGGED ARITHMETIC 


by Paula J. Bettinger, Andrew M. Manos, and Betty Jo Armstead 

Lewis Research Center 

SUMMARY 

A special tagged arithmetic system has been developed for use with FORTRAN pro- 
grams written to process experimental data. The tagged arithmetic system carries a 
condition code with every numerical value and uses a letter code on the output to call 
attention to answers computed by using questionable input data. This system eliminates 
stops from process-time faults or error conditions and permits calculations to be com- 
pleted with questionable data. It reduces the programing effort formerly required to 
detect faulty input and thus avoid ill-conditioned calculations. Reprocessing of data is 
significantly reduced, and the user's confidence in results is increased. 


INTRODUCTION 

Most of the experimental data processed at Lewis are digitized quantities of physical 
measurements recorded by central and remote data recording systems. Since the data 
are a result of direct measurements, some of the data recorded might lead to impossible 
operations (e. g. , division by zero or the square root of a negative number). For the 
most part, these data are due to instrument failures or to test point settings where a 
small error in data causes the calculations to be ill- defined. In many cases, such data 
can produce plausible, but incorrect, results. Complete error analysis of the source of 
these faults is impractical to perform internally in the computer while processing the 
data. Therefore, the calculations must be programed to proceed in the best manner 
possible, and the questionable data flagged for analysis later. A tagged arithmetic sys- 
tem was designed to aid in the analysis of the experimental data and subsequent calcula- 
tions performed with the data. 

The system was first developed by Mr. L. Richard Turner of Lewis. It was imple- 
mented in a special interpretive data processing system in use on the UNIVAC 1103 com- 



puter. The present tagged arithmetic system was written for use with FORTRAN IV pro- 
grams running on the IBM 7094II/704X direct couple systems. It has been in use since 
the spring of 1966. The system has proved to be extremely useful and thus was also im- 
plemented for FORTRAN programs running on the 360/67 with Operating System 360. 

We know of no other software system or computer designed to carry a condition code 
along with the data throughout the calculations. 


OVERVIEW OF SYSTEM 

The tagged arithmetic system allows processing of data to proceed regardless of the 
quality of the data. Questionable input data and further calculations based on it are 
tagged as the data are processed. The appearance of a letter printed immediately to the 
right of the results on the output alerts the research engineer that his results may be 
questionable. This letter enables him to analyze the causes of the flag and to make judg- 
ment as to the validity of the results. Figure 1 shows sample output from the tagged 
arithmetic system. 

The basis for tagging questionable data consists of one or more of the following 
elements: 

(1) Instrument failure 

(2) Digitizer limitations (data exceeding range) 

(3) Faulty data syntax 

(4) Parity errors 

(5) Violation of calibration limits 

(6) Programed validity test failure 

(7) Impossible arithmetic operation 

A word can be tagged at recording time either by the engineer's choice or by the re- 
cording hardware (i.e. , parity errors). It can be tagged at execution time either by the 
programer's choice or by the operating system as a result of an impossible arithmetic 
operation or an operation with a previously tagged word. 

The four basic categories of tags are defined as follows 

(1) Input tag or engineer's code-out: An input tag must be generated by the data re- 
cording systems and/or subprograms which analyze the digitized input of experimental 
data. This tag is inserted for data which exceed the limit of a digitizer, have parity 
errors, or have faulty syntax. An engineer can tag data caused by faulty instrumentation 
by use of the central data recording systems or remotely by use of a plugboard at the site 
or through communication with the processing programs. Any calculations subsequently 
based on data with an input tag would also contain the input tag. 
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(2) Programed validity test failure: This tag is generated by the programer and will 
take on whatever meaning he desires. It could be used to specify that the number of 
iterations has exceeded a limit or that a data point has an excessive deviation from a 
curve fit. 

(3) Computer overflow or impossible operation: This tag is reserved for use by the 
floating-point trap error package which resides in the system. No other source is per- 
mitted to insert this tag. The error package (NASA Lewis Research Center 709411/7044 
Direct Couple Monitor Program Reference Manual) in use on the Lewis direct couple 
computer can establish the existence of the tagged arithmetic system within a particular 
program and insert tags whenever an impossible operation occurs. For example, the 
tag might be caused by dividing by zero or taking a square root or logarithm of a nega- 
tive number. 

(4) Calibrations outside a declared range: In processing experimental data an en- 
gineer must specify calibrations for the data. A tag is generated whenever a calibrated 
value falls outside the range for which the calibration has been specified as valid. 

The value of tagged arithmetic depends on its proper use by the engineer and pro- 
gramer. When proper precautions have been taken at the recording facility and in the 
program to insert the necessary tags, data faults will naturally propagate throughout the 
processing of the data, enabling the engineer to analyze the results of his experiment. 
The appearance or absence of tags on the printed results gives the engineer an easy clue 
to the reliability of the processed data. 

Tagged arithmetic can be used in other applications. With the exception of the im- 
possible operation, the user can give his own meaning to the categories of tags and use 
them to trace the effects of specific data or the flow within a program. 


LIMITATIONS 

The tagged arithmetic system was designed with the programer, as well as the re- 
search engineer, in mind. It was considered undesirable to place restrictions on the 
programer beyond those that were already part of the operating system; however, a few 
minor restrictions were found necessary. 


Programing Restrictions 

The following restrictions are placed on programs using tagged arithmetic: 

(1) Library routines ATAN, ATAN2, GAMMA, ALGAMA, ERF, TANH, TAN, and 
COTAN must not be referenced for any data that might be tagged. Instead, the entry 
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names TAT AN, TATAN2, T GAMMA, TLGAMA, TERF, TTANH, TTAN, and TCOTAN 
are provided to handle tagged arguments. All other library routines may be referenced 
normally. 

(2) On large jobs that require overlay, non- FORTRAN library subprograms must be 
included in the main link. 

(3) Output fields for numbers that may be tagged must be large enough to accommo- 
date the alphameric character that represents the tag. In the field specifications Ew. d, 
Fw. d, and Gw. d both w and d are reduced by 1 to write out a tagged number. In the 
programer's format specification, d must not be zero. 

(4) The load-time debugging package provided by IBM (IBJOB Processor Debugging 
Package ($IBDBL, * DEBUG, etc.)) may be used if two rules are followed: 

(a) Debug requests may only be made at the beginning of a FORTRAN statement. 
(This is normal for FORTRAN programs. ) 

(b) Debug requests may not be made on any statement that may result in a sub- 
routine CALL as its first operation (i.e. , CALL, READ, WRITE, X = SQRT(X), etc. ). 
Requests may not be made on a CONTINUE statement which immediately precedes the 
above types of statement. 

Tagged numbers printed by debug requests will appear half the magnitude they are and 
will not be followed by an alphabetic tag since the debug package does not make any spe- 
cial provision to recognize tagged numbers. 

(5) The standard method of handling arithmetic errors (NASA Lewis Research Center 
709411/7044 Direct Couple Monitor Program Reference Manual) is slightly altered when 
using tagged arithmetic. The differences are as follows: 

(a) The result of all illegal arithmetic operations, except underflows, will be 
tagged with a computer overflow or impossible operation tag. 

(b) Division by zero will always be treated as an overflow (i. e. , the result is 
set to the largest representable floating-point number). Otherwise, the programer's 
control of errors is not altered. 

(6) FORTRAN logical expressions do not make any provision to handle tagged num- 
bers. An arithmetic expression or variable which is tagged is used in comparisons as 
follows: 

(a) A tagged zero is not equal to zero. 

(b) A tagged nonzero is half magnitude. 


Storage Requirements and Timing 

Routines of the tagged arithmetic system add less than 1000 words to the storage re- 
quired for the basic programs. Inclusion of all the optional routines adds less than an- 
other 500 words. 
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A typical data processing job may require twice as much execution time with the 
tagged arithmetic system. The disadvantage of a longer run time is more than over- 
come by the advantages of being able to complete a run in spite of questionable data and 
to evaluate the results with any errors automatically propagated to the resulting output. 
This reduces the necessity for reprocessing because of questionable data. 


IMPLEMENTATION 

The tagged arithmetic system is implemented for use with programs written in 
FORTRAN IV. Several modifications were made to the operating system to accommo- 
date tagged arithmetic. To further facilitate the scanning and alteration of programs, 
the system library was ordered to separate routines which need to be scanned from those 
which do not. These changes in no way affect execution of jobs which do not use the 
tagged arithmetic system. 


Tagged Format 

The sign and characteristic portions of tagged and untagged data words are the same. 
However, a tagged data word in machine memory is always unnormalized by shifting the 
mantissa portion one bit position to the right. This gives the tagged data word a unique 
form. 

The four low- order bits of a tagged data word are used to express four categories of 
faults, as shown in appendix A. Each bit position in the four-bit tag represents a differ- 
ent category of fault. The tag is then the logical OR of the faults which appeared in op- 
erands that produced this data word. There are 22 bits to express the significant man- 
tissa, which is considered sufficient for questionable data. Untagged data words suffer 
no loss of precision. The tagged arithmetic system uses only single-precision (36 bit) 
floating-point words. 


Instruction Alteration and Recognition 

The tagged arithmetic system inserts a mask into every floating-point operation 
(addition, subtraction, multiplication, and division) and calls to certain mathematical 
functions. The first octal digit of each of these commands is 0 and is changed to 5. 

When this changed command is executed, the location of the operation is stored, and 
control is transferred to a fixed location in the core (i. e. , a STORE AND TRAP occurs). 
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This fixed location then sends control to the arithmetic portion of the tagged arithmetic 
system. The system removes the mask to recover the original floating-point operation. 
Control is thus transferred to the system before each floating-point operation to check 
for the existence of a tagged operand. If there is no tagged operand, the operation is 
performed normally (after removing the mask). Otherwise, the special tagged arith- 
metic operations must be used to preserve and propagate the tags, as well as to perform 
the arithmetic operation specified. 


Tagged Arithmetic Subprograms 

The tagged arithmetic system includes 13 subprograms. A description of each of 
these subprograms is given in appendix B. One subprogram is available to the pro- 
gramer for invoking the tagged arithmetic system. Eight subprograms are available to 
the programer for examining the tags of numbers, for inserting tags, and for special 
entries to library routines that would not otherwise be able to handle the tagged numbers. 
The remaining subprograms are called automatically and do not need to be known by the 
programer . 

The programer must call the subprogram TAGSCN to activate the tagged arithmetic 
system before executing any other instructions. This subprogram determines the areas 
of core storage to be scanned for floating-point arithmetic operations. Two areas are 
scanned, the object program loaded by the programer and all standard library subpro- 
grams. TAGSCN calls the SCANTG subprogram, which scans the necessary portion of 
the core and replaces floating-point operations and certain library subprogram calls so 
that they will be tested for tagged arithmetic when executed. The replaced operations 
are addition, subtraction, multiplication, and division, or any of the transfers to the 
functions SIN, COS, EXP, SQRT, ASQRT, ALOG, and ALOGIO. 

During execution, the TAGOPE subprogram is entered when an operand is a tagged 
number. Floating-point arithmetic operations and transfers to the functions SIN, COS, 
EXP, SQRT, ASQRT, ALOG, and ALOGIO are examined by this subprogram. The tag or 
tags of the operands are removed, the indicated operation is performed, and the result 
is flagged with the combined tags of the operands. The subprogram TAGPF is called for 
the special library routines TATAN, TATAN2, TGAMMA, TLGAMA, and TERF written 
to replace routines that operate on the characteristic and mantissa of a floating-point 
argument separately rather than using the standard machine floating-point operations. 


Operating System Modifications 

Several modifications were made to the operating system to accommodate the tagged 
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arithmetic system. These in no way affect the execution of jobs which do not use tagged 
arithmetic. The modifications were as follows: 

(1) Reference points were inserted so that information available to the operating 
system could also be referenced by the tagged arithmetic system. 

(2) The standard error package in use at Lewis reports arithmetic errors that cause 
a machine overflow, underflow, division by zero, or an attempt to use an illegal argu- 
ment to a standard library arithmetic function The standard error package was modi- 
fied so that it would insert the appropriate tag into the result of an impossible operation. 
Error reports are not given if an operand was previously tagged. 

(3) Output conversion of floating-point numbers was modified to recognize a tagged 
number. The conversion normalizes the number and adjusts the field specification to 
include an alphameric character to represent the appropriate tag. 

(4) The routine which overlays links or large jobs was modified to call for a scan of 
the appropriate area each time a new link is read into the memory. A table of subrou- 
tine locations and link numbers is preserved in lower memory by the loader. The loader 
has been modified to save this table for the Lewis error package. 

(5) To further facilitate the scanning and alteration of programs, the system library 
was reordered to separate routines which need to be scanned from those which do not. 


CONCLUDING REMARKS 

A special tagged arithmetic system has been developed at Lewis Research Center 
for use with FORTRAN programs written to process experimental data. The tagged 
arithmetic system carries a condition code with every numerical value and uses a letter 
code on the output to call attention to answers computed using questionable input data. 

The programing restrictions for use of the tagged arithmetic system with FORTRAN 
programs are relatively minor. Considerable programing time is saved by use of the 
system. The system performs decisions and flags results which otherwise would have 
to be programed for each experimental test. The disadvantages of the longer run time 
are more than overcome by the advantages of being able to complete a run in spite of 
questionable data and to evaluate the results with flags automatically propagated to the 
resulting output. This reduces the necessity for reprocessing because of questionable 
data. 
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The tagged arithmetic system has applications other than processing data which are 
the results of physical experiments. The bit structure which includes a tag and propa- 
gates it through calculations is useful in tracing and general program debugging. 

Lewis Research Center, 

National Aeronautics and Space Administration, 

Cleveland, Ohio, June 9, 1969, 

129-04-06-03-22. 


8 


APPENDIX A 


BIT STRUCTURES OF TAGGED REAL NUMBERS USED IN FORTRAN 
PROGRAMS WITH FLOATING ARITHMETIC TRAPS 


Let S, E, N, and F represent the sign, exponent, numeric, and fault bits of the 
real number, respectively. The effect of tagging on the zero and nonzero bit structures 
can be represented as follows: 


S 00000000 00000000000000000000000 0000 
S 00000001 00000000000000000000000 FgF 4 F 2 F 1 
S EEEEEEEE 1 NNNNNNNNNNNNNNNNNNNNN^ N N N N 
S EEEEEEEE 0 1 NNNNNNNNNNNNNNNNNNNNN FgF^Fj^ 


Untagged zero data 
Tagged zero data 
Untagged nonzero data 
Tagged nonzero data 


The interpretation of the fault bits is as follows: 


Fg Input tag or engineer's code- out 

F^ Failure of programed test for validity 

Fg Computer overflow or impossible operation 

Fj Data word outside declared range 

Example: 

201400000000 Octal representation of a floating-point untagged 1 
201200000005 Floating-point 1 tagged with F^ and F^ bits 

Tagged data output can warn the engineer that a data word is doubtful or faulty. The 
output of a FORTRAN program using F, E, or G format conversion for real single- 
precision tagged data words will yield a literal tag appended to the right of the printed 
result. An example of this output using 016, F16. 6, E16. 6, and G16. 6 oh a normal zero, 
a zero with an input tag, a normal 1, and a 1 with both an input and an out-of-range 
tag is illustrated as follows: 
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Conversion 

Untagged zero 

Tagged zero 

Untagged 1 

Tagged 1 

016 (octal) 

000000000000 

001000000010 

201400000000 

201200000011 

F16.6 

0 

0. 00000H 

1.000000 

1.00000S 

E16.6 

0 

0 00000E-38H 

0. 100000E 01 

0. 10000E 01S 

G16.6 

0 

0. 00000E-38H 

1.000000 

1.00000 S 


The tag letters that can appear in the output, such as H and S in the previous illustra- 
tion, can be interpreted by means of the following key: 


Tag value 

Tag meaning 

Tag letter 

A 

B 

C 

D 

E 

F 

G 

H 

S 

T 

U 

V 

w 

X 

Y 

8 

Input tag 








* 

* 

* 

* 

* 

* 

* 

* 

4 

Failure of programed test for validity 




* 

* 

* 

* 





* 

* 

* 

* 

2 

Impossible operation 


* 

* 



* 

* 



* 

* 



* 

* 

1 

Out of declared range 

* 


* 


* 


* 


* 


* 


* 


* 
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APPENDIX B 


SUBROUTINES USED WITH TAGGED ARITHMETIC 

The subroutines used with tagged arithmetic are given in the following table: 


Subroutine 

Usage 

Call sequence 

Error message 

Error condition 

Optional exit 
control 

NTAG 

Finds tag of tagged number, 
if any 

y = NTAG(x) 

None 

None 

None 

TAG 

Tags a number 

CALL TAG(x, n) 

* ATTEMPT TO TAG 
A NONREAL GAVE 
A TAGGED ZERO 

n is not real 

$LIBSAR 

TAGSCN 

Sets all floating-point oper- 
ations for possible tagged 
arithmetic; determines 
proper error conditions 

CALL TAGSCN 

None 

! 

None 

None 

UNTAG 

Removes tag from tagged 
number 

y = UNTAG(x) 

None 

None 

None 

TATAN 

Calls ATAN for argument 
that may be tagged 

y = TATAN (x) 

None 

None 

None 

TATAN2 

Calls ATAN2 for argument 
that may be tagged 

y = TATAN2(x, z) 

* ILLEGAL ARG. 
TAGGED ATAN2 

x or z is non- 
real, nontagged 

$LIBSAR 

TERF 

Calls ERF for argument that 
may be tagged 

y = TERF (x) 

None 

None 

None 

T GAMMA 

Calls GAMMA for argument 
that may be tagged 

y = TGAMMA(x) 

None 

None 

None 

TLGAMA 

Calls ALGAMA for argu- 
ment that may be tagged 

y ^ TLGAMA (x) 

None 

None 

None 

a SCANTG 

Changes floating-point oper- 
ations to tagged operations 

None 

None 

None 

None 

a TAGTRP 

Tests operands for tagged 
numbers and performs 
normal arithmetic opera- 
tions; sets up output for 
tagged numbers 

None 

None 

None 

None 

a TAGOPE 

Performs tagged arithmetic 

None 

None 

None 

None 

a TAGPF 

Provides linkage to function 
subprograms for tagged 
arguments 

None 

None 

None 

None 


a Used automatically and are not called by the programer. 
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Subroutine TAGSCN (Written in MAP) 

This subroutine must be called by the program before any other statements are exe- 
cuted in order to use any tagged arithmetic during execution of the program. It deter- 
mines the areas of core storage to be scanned for possible floating-point arithmetic oper- 
ations. Two areas will be scanned, the object program loaded by the programer and all 
standard library subroutines. Three areas are not scanned. These include the resident 
portion of the IBJOB monitor system itself; nonstandard, non-FORTRAN library routines; 
and that portion of core storage beyond the loaded object program and library. TAGSCN 
calls subroutine SCANTG. 


Subroutine SCANTG (Written in FORTRAN IV) 

This subroutine actually scans the necessary part of the core and replaces floating- 
point operations and certain library routine calls so that they may be tested for tagged 
arithmetic when executed. The first octal digit is set to 5, which will cause (1) the in- 
struction counter to be stored and (2) an illegal operation trap. These operations are 
addition, subtraction, multiplication, and division, or any of the transfers to the func- 
tions SIN, COS, EXP, SQRT, ASQRT, ALOG, and ALOGIO. 

Subroutine TAGOPE (Written in FORTRAN IV) 

TAGOPE is entered when an operand is a tagged number. The tag or tags of the op- 
erands are removed, the indicated operation is performed, and the result is tagged with 
the combined tags of the operands. Permissible operations are addition, subtraction, 
multiplication, and division, or one of the functions SIN, COS, EXP, ALOG, SQRT, 
ASQRT, and ALOGIO. 


Subroutine TAGPF (Written in FORTRAN IV) 

This logical function will determine if the operand is a tagged number. If it is 
tagged, a function subprogram will be called to operate on the argument and the function 
will be set . TRUE. . This function is used by the special library routines that were 
written to replace routines that operate on the characteristic and mantissa of a floating- 
point argument separately rather than by using the standard machine floating-point op- 
erations. 
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Subroutine TAGTRP (Written in MAP) 


This subroutine recognizes a command that may be a possible tagged arithmetic op- 
eration. If neither operand is tagged, the operation is performed normally. If either 
one is tagged, TAGOPE is called to perform the operation. This routine also controls 
the output conversion of tagged numbers in the E or F conversion. If a number to be 
written out is tagged, the alphabetic tag will appear in the rightmost position of the speci- 
fied field, thus causing one less significant digit to appear. 


Subroutine NTAG (Written in FORTRAN IV) 

This function subprogram is used in a FORTRAN tagged arithmetic data processing 
job to determine whether a single-precision floating-point number is tagged. An integer 
is generated, the value of which depends on the fault conditions that apply to the number . 
The value of that integer is obtained by a reference to NTAG(X) . The relations among the 
value of the integer, the letter used to tag this number in output, and these fault condi- 
tions are illustrated as follows: 


Fault conditions that apply to number X 

Tag bits 
of X 





Value of 

NTA G(X) 




— 

1 

ll 

Li 

Li 


\±. 

t. 

K 


I 10 

i“ 


in 

l» 

n 

Tag letter 

A 

B 

c 

D 

E 

F 

G 

H 

S 

T 

U 

V 

w 

X 

Y 

Input tag or engineer’s code -out 

8 








* 

* 

* 

* 

* 

* 

* 

* 

Failure of programed test for validity 

4 




* 

* 

* 

* 





* 

* 

* 

* 

Computer overflow or impossible operation 

2 


* 

* 



* 

* 



* 

* 



* 

* 

Data word outside of declared range 

1 

* 


* 


* 


* 


* 


* 


* 


* 


When X is untagged, NTAG(X) is zero. When X is not a single- precision floating- 
point number, such as when X is an integer, NTAG(X) is set to the value -31. 


Subroutine TAG (Written in FORTRAN IV) 

This subroutine is used to set specified fault bits, called the tag, of a real, single- 
precision, floating-point data word. The tag is used to specify fault conditions that apply 
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to the data word; the tag NN is defined as follows: 

NN=8 input tag or engineer's code-out 
NN=4 failure of programed test for validity 
NN=2 computer overflow or impossible operation 
NN=1 data word has fallen outside declared range 

Tags propagate through tagged arithmetic to the results of the calculation. When E, 
F, or G format conversions are used for output, the tags are reported as literal tags. 
Insertion of a tag is made by the statement 

CALL TAG(X, N) 


where 

X data word to be tagged 

N fixed-point variable or constant, sum of all values of NN to be inserted with this 
CALL 

Define n congruent to N modulo 16. 

(1) When n = 0, X is left unchanged. 

(2) When X is untagged, the resulting tag of X is n. 

(3) When X is tagged, the resulting tag of X is the logical sum of n and the orig- 
inal tag of X. 

(4) An NN=2 in n is ignored. The programer cannot control this bit. The re- 
lation among n, the letter tag in the output, and the fault bits is given as follows: 


Tag bit 






Value of 

n 







1 

1l 

\l 

li 

li. 

E 

E 

E 

E 

10 

lL> 

1“ 

1,3 

I 14 

1- 


Tag letter 


A 

B 

c 

D 

E 

F 

G 

H 

s 

T 

u 

V 

w 

X 

Y 

NN=8 








* 

* 

* 

* 

* 

* 

* 

* 

NN=4 




* 

* 

* 

* 





* 

* 

* 

* 

NN=2 


* 

* 



* 

* 



* 

* 



* 

* 

NN=1 

* 


* 


* 


* 


* 


* 


* 


* 


When X is nonreal, such as an integer, the following error message is returned by the 
Execution Error Monitor: 

* ATTEMPT TO TAG A NONREAL GAVE A TAGGED ZERO 
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Subroutine UNTAG (Written in FORTRAN IV) 


This subroutine may be used to remove the tag from a number. If the number has 
been tagged, the accuracy is limited to the 22 bits available in the mantissa. The state- 
ment 


Y = UNTAG (X) 

stores the untagged value of X in Y. Programers are cautioned about the use of this 
routine so that the purpose of tagged arithmetic is not wasted. 


Subroutines TATAN, TATAN 2, TGAMMA, TLGAMA, andTERF 
(Written in FORTRAN IV) 

These function names are used to reference the respective functions whenever there 
is a possibility that an argument may be a tagged number. These names should always 
be used by a program that uses tagged arithmetic. 


Use 


z = TATAN (x) 
z = TATAN2 (x, y) 
z = TGAMMA(x) 
z = TLGAMA(x) 
z = TERF(x) 


Do not use 


z = AT AN (x) 
z = ATAN2 (x, y) 
z = GAMMA (x) 
z = ALGAMA(x) 
z = ERF(x) 


Each of these routines calls TAGPF. An entry into the normal library routine is then 
effected with an untagged argument. If any tag is present, it will be propagated in the 
function value before return to the user's program. 
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Figure 1 


NASA-LEWiS RESEARCH CENTER CLEVELAND, OHIO PRELIMINARY DATA 01/15/69 CADDE-II RECORDED 1 3 21 50 40 438 

FACILITY PSL-2 PROD 0007 RDO 0137 

bARQM = 14.3EPSIA 


AVD 

1 

2 

3 


4 

5 

6 


7 

8 

9 


10 


1-51.0232 

-53.8371 

-683.37 

A- 

-6 72.343 

-3.44234 

498.486 


9399.21 

9388.88 

9393.47 


12707.1 


U 

12699.8 

12699.8 

20.4088 


25.4037 

18.7015 

9.15292 


4.52307 

4.44765 

4.5661b 


0. 13301 E- 

01 

21 

9.06191 

2.99680 

-0. 86 ri9E- 

02 

0 

519.871 
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